## **JoltCore Spark 16: Instruction Set**

5 bit

3 bit

| Instruction Name                                    | Description                                                                                                                                                                                                              | Binary                                                                                                                     | Arguments                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Implmtd.?            |
|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| ALU operations                                      |                                                                                                                                                                                                                          |                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| add sub and not or xor nand nor lshift rshift gt lt | Add two values together Subtract two values Bitwise AND Bitwise NOT Bitwise OR Bitwise XOR Bitwise NAND Bitwise NOR Bit shift left by one Bit shift right by one Is greater than Is less than Is equal reserved reserved | 00000<br>00001<br>00010<br>00011<br>00100<br>00101<br>00110<br>00111<br>01000<br>01001<br>01010<br>01011<br>01100<br>01101 | REG-ID-DEST, REG-ID1, REG-ID2 REG-ID-DEST, REG-ID1, REG-ID2 REG-ID-DEST, REG-ID1, REG-ID2 REG-ID-DEST, REG-ID, NULL REG-ID-DEST, REG-ID1, REG-ID2 | Reserved<br>Reserved |
|                                                     | reserved                                                                                                                                                                                                                 | 01111                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reserved             |
| Control flow operations                             |                                                                                                                                                                                                                          |                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| jmp<br>jiz<br>jnz<br>jic<br>jnc                     | Jump to Instruction Jump if last ALU OP = zero Jump if last ALU OP != zero Jump if ALU had carry Jump if ALU had no carry                                                                                                |                                                                                                                            | NULL, TARGET INSTRUCTION ID<br>NULL, TARGET INSTRUCTION ID<br>NULL, TARGET INSTRUCTION ID<br>NULL, TARGET INSTRUCTION ID<br>NULL, TARGET INSTRUCTION ID                                                                                                                                                                                                                                                                                                       | Reserved<br>Reserved |
| Storage & I/O operations                            |                                                                                                                                                                                                                          |                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| oclk<br>ldi<br>ldram<br>stram<br>rdpin<br>wrpin     | Emit a clock signal to CLK Load immed. into register Load from RAM into reg. Store register into RAM Read value from pin to reg Write value from pin to reg                                                              | 10111<br>11000<br>11001<br>11010<br>11011<br>11100                                                                         | 000 REG-ID-DEST, VALUE REG-ID-DEST, RAM-ADDR REG-ID, RAM-ADDR REG-ID-DEST, REG-ID1 REG-ID-DEST, REG-ID1                                                                                                                                                                                                                                                                                                                                                       |                      |
| halt                                                | Stops execution                                                                                                                                                                                                          | 11101<br>11110<br>11111                                                                                                    | 000                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reserved<br>Reserved |
| Command outline                                     |                                                                                                                                                                                                                          |                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| Instruction                                         | Destination register                                                                                                                                                                                                     |                                                                                                                            | Further arguments<br>(a.e. 2 registers = 6 bit)<br>(a.e. immediate = 16 bit)                                                                                                                                                                                                                                                                                                                                                                                  |                      |

Max. 16 bit

min. 14 bit, max. 24 bit

Register bin.